<template>
  <div>
    <Header :left="true" leftText="返回" title="生产异常上报" />
    <div>
      <div style="margin-top: 10px; margin-bottom: 10px;margin-left: 20px;">
        <van-button type="primary" class="buttongroup1" @click="hideSearch" color="#138087">查询条件</van-button>
      </div>
      <div style="height: 15erm" v-if="showeSearch">
        <Form :style="autoHeight">
          <van-field class="formstyle" v-model="form.MachineID" name="设备代码" label="设备代码" placeholder="输入设备代码" />
          <van-field class="formstyle" v-model="form.PShiftID" name="班次" label="班次" placeholder="输入班次" />
          <van-field class="formstyle" v-model="form.POrderID" name="生产订单" label="生产订单" placeholder="输入生产订单" />
        </Form>
        <div style="margin-top: 10px; margin-bottom: 10px">
          <van-button type="primary" class="buttongroup" @click="getMachineAbnormalSubmitedList"
            color="#138087">查询</van-button>
        </div>
      </div>

      <div class="textScroll" id="textScroll">
        <!-- 循环数据开始 -->
        <div v-for="(item, index) in itemsOne" :key="item.Id" style="position: relative">
          <div style="width: 100%; background-color: #f3f4f8; height: 5px">
            <span></span>
          </div>
          <div class="divStyle">
            <van-row style="margin-left: 10px; margin-top: 10px">
              <van-col span="18"><b>编号:</b>{{ index + 1 }}</van-col>
            </van-row>
            <van-row style="margin-left: 10px; margin-top: 10px">
              <van-col span="10"><b>设备代码:</b></van-col>
              <van-col span="14">{{ item.MachineID }}</van-col>
            </van-row>
            <van-row style="margin-left: 10px; margin-top: 10px">
              <van-col span="10"><b>异常类型:</b></van-col>
              <van-col span="14">{{ item.AbnormalTypeID }}</van-col>
            </van-row>

            <van-row style="margin-left: 10px; margin-top: 10px">
              <van-col span="10"><b>异常发生时间:</b></van-col>
              <van-col span="12">{{ item.OccurDatetime }}</van-col>
              <van-col span="2">
                <van-button style="
                    width: 85px;
                    height: 40px;
                    font-size: 12px;
                    position: absolute;
                    left: 80%;
                  " type="primary" color="#138087" text="查看详情" @click.stop="seeCheckedDetail(item)" />
              </van-col>
            </van-row>

            <van-row style="margin-left: 10px; margin-top: 10px">
              <van-col span="10"><b>班次选择:</b></van-col>
              <van-col span="14">{{ item.PShiftID }}</van-col>
            </van-row>

            <van-row style="margin-left: 10px; margin-top: 10px">
              <van-col span="10"><b>生产订单:</b></van-col>
              <van-col span="14">{{ item.POrderID }}</van-col>
            </van-row>
            <van-row style="margin-left: 10px; margin-top: 10px">
              <van-col span="10"><b>物料代码:</b></van-col>
              <van-col span="14">{{ item.MaterialID }}</van-col>
            </van-row>
            <van-row style="margin-left: 10px; margin-top: 10px">
              <van-col span="10"><b>物料名称:</b></van-col>
              <van-col span="14">{{ item.MaterialName }}</van-col>
            </van-row>
            <van-row style="margin-left: 10px; margin-top: 10px">
              <van-col span="10"><b>异常信息描述:</b></van-col>
              <van-col span="14">{{ item.AbnormalDescription }}</van-col>
            </van-row>
          </div>
          <div>
            <br />
          </div>
        </div>
      </div>
    </div>
  </div>
</template>


<script>
import {
  Col,
  Row,
  Form,
  Cell,
  Icon,
  Field,
  NumberKeyboard,
  Image as VanImage,
  Picker,
  popup,
  SubmitBar,
  Button,
  Loading,
  Overlay,
  Dialog,
  tab,
  tabs,
  Toast,
  NoticeBar,
  Tag,
  DatetimePicker,
  ImagePreview,
  CellGroup,
  Uploader,
  Cascader,
  Calendar,
  RadioGroup,
  Radio,
  Divider,
  Stepper,
  AddressList,
  Checkbox,
  CheckboxGroup,
} from "vant";

import "vue-easytable/libs/themes-base/index.css";
import { VTable } from "vue-easytable";
import { _httpClient } from "@/libs/apisie";
import { getToken, getBaseApiFrefix } from "@/libs/auth";
import Header from "@/components/header.vue";
import { storage } from "@/libs/utils";
import { _httpClient as _httpClientApisie } from "@/libs/apisie";
import { _httpClient as _httpClientApi } from "@/libs/api";

Vue.use(Form);
Vue.use(Field);
Vue.use(Overlay);
Vue.use(Loading);
Vue.use(tabs);
Vue.use(Picker);
Vue.use(popup);
Vue.use(SubmitBar);
Vue.use(VanImage);
Vue.use(DatetimePicker);
Vue.use(Cascader);
Vue.use(Calendar);
Vue.use(Cell);
Vue.use(RadioGroup);
Vue.use(Radio);
Vue.use(Divider);
Vue.use(Stepper);
Vue.use(Button);
Vue.use(AddressList);
Vue.use(Checkbox);
Vue.use(CheckboxGroup);
Vue.use(Col);
Vue.use(Row);
Vue.use(tab);

export default {
  name: "laboratoryTestData",
  components: {
    tab,
    Form,
    Row,
    Col,
    Button,
    Header,
    Form,
    Cell,
    Icon,
    Field,
    NumberKeyboard,
    Dialog,
    Toast,
    NoticeBar,
    Row,
    Tag,
    popup,
    DatetimePicker,
    ImagePreview,
    CellGroup,
    Uploader,
    Col,
    Calendar,
    Cascader,
    Picker,
    RadioGroup,
    Radio,
    Divider,
    Stepper,
    VTable,
    AddressList,
    Checkbox,
    CheckboxGroup,
  },

  data() {
    return {
      itemsOne: [],
      form: {
        MachineID: "",
        PShiftID: "",
        POrderID: "",
      },
      showeSearch: false,
    };
  },

  created: function () {
    let oldHight = api.winWidth;
    this.screenWidth = oldHight;
    this.getMachineAbnormalSubmitedList();
  },
  async mounted() { },

  methods: {
    //查询生产异常管控信息
    async getMachineAbnormalSubmitedList() {
      let _this = this;
      Toast.loading({
        mask: true,
        forbidClick: true,
        duration: 0,
        message: "Loading...",
      });
      try {
        let res = await _httpClient.get(
          _httpClient.getApiPrefix() +
          "/MachineAbnormalSubmited/GetList?MachineID=" +
          _this.form.MachineID +
          "&PShiftID=" +
          _this.form.PShiftID +
          "&POrderID=" +
          _this.form.POrderID
        );
        if (res.Total === 0) {
          Toast.clear();
        } else {
          Toast.clear();
          _this.itemsOne = res.Data;
        }
      } catch (e) {
        Toast.fail(JSON.stringify(e));
      }
    },
    seeCheckedDetail(val) {
      let _this = this;
      this.$ac.openWin({
        name: "queryProductionAnomalyReportingItem01",
        url: "./productionanomalycontrol-queryProductionAnomalyReportingItem01.html",
        pageParam: {
          item: val,
        },
      });
    },
    async hideSearch() {
      if (this.showeSearch == false) {
        document.getElementById("textScroll").style.top = "45%";
        this.showeSearch = true;
      } else {
        this.showeSearch = false;
        document.getElementById("textScroll").style.top = "16%";
      }
    },
    formatDate(date) {
      return `${date.getFullYear()}/${date.getMonth() + 1}/${date.getDate()}`;
    },
  },
};
</script>

<style>
body {
  background-color: white;
}

.table-title-class {
  background-color: #304156;
  color: #fff;
}

.wrapper {
  display: flex;
  align-items: center;
  justify-content: center;
  height: 100%;
}

.buttongroup {
  float: right;
  width: 30%;
  margin-right: 10px;
  margin-top: 10px;
  margin-bottom: 20px;
}

.buttongroup1 {
  float: left;
  width: 30%;
  margin-right: 10px;
  margin-top: 10px;
  margin-bottom: 20px;
}

.container.dwo {
  display: flex;
  justify-content: center;
  align-items: center;
}

.buttonLeft {
  position: fixed;
  bottom: 8px;
  float: left;
  width: 49%;
}

.formstyle {
  font-size: 15px;
  font-weight: bold;
  display: flex;
  align-items: center;
}

.radioteam {
  display: flex;
  align-items: center;
  padding-left: 13px;
  margin-top: 10px;
  margin-left: 34px;
  margin-bottom: 10px;
}

.buttonRight {
  position: fixed;
  bottom: 8px;
  float: right;
  left: 51%;
  width: 49%;
  background-color: #f22028;
  border-color: #f22028;
}

.textScroll {
  display: inline-block;
  position: fixed;
  top: 16%;
  bottom: 3rem;
  overflow: scroll;
  right: 10px;
  width: 100%;
  z-index: 1;
}

.message {
  font-size: 15px;
  margin-top: 5px;
  margin-left: -10px;
  font-weight: bold;
}

.mg5 {
  margin-right: 5px;
}

.tag_margin {
  margin: 2px 5px;
}

.card_under {
  height: 100%;
  width: 100%;
  margin: auto;
  background: #ffffff;
  border-radius: 25px;
  box-shadow: 0 0px 0px rgba(0, 0, 0, 0.3);
}

.card_icon {
  text-align: center;
  /* position: absolute; */
  height: 8rem;
  width: 80%;
  margin: 12% 10%;
  background: rgba(35, 180, 237, 1);
  border-radius: 25px;
  box-shadow: 0 10px 50px rgba(0, 0, 0, 0.3);
}

.text {
  font-size: 18px;
  color: #4e4a67;
  margin: 8px auto auto 20px;
  line-height: 1.5rem;
  text-align: justify;
  font-weight: 600;
}

.text_small {
  font-size: 16px;
  color: red;
  margin: 8px auto auto 20px;
  line-height: 1.5rem;
  text-align: justify;
  font-weight: 700;
}

.text_scan {
  font-size: 16px;
  color: #4e4a67;
  margin: auto auto auto 20px;
  line-height: 1.5em;
  text-align: justify;
}

.divStyle {
  /* border: 1px solid #dcdcdc; */
  border-top-width: 3px;
  border-left-width: 3px;
  margin-left: 3px;
  margin-right: 3px;
  margin-top: 0px;
}
</style>
